import java.util.HashMap;
import java.util.Map;

public class Solution1 {
    public int subarraySum(int[] nums, int k) {
        Map<Integer,Integer> hash = new HashMap<>();
        hash.put(0,1);
        int sum = 0;
        int ret = 0;
        for(int x : nums) {
            sum += x;//计算当前位置的前缀和
            ret += hash.getOrDefault(sum - k , 0);//统计结果
            hash.put(sum, hash.getOrDefault(sum, 0) + 1);//把当前的前缀和丢进哈希表里
        }
        return ret;
    }
}
